active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
↳ QTRS
↳ DependencyPairsProof
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
ACTIVE(f(b, X, c)) → F(X, c, X)
MARK(f(X1, X2, X3)) → MARK(X2)
ACTIVE(f(b, X, c)) → MARK(f(X, c, X))
F(X1, mark(X2), X3) → F(X1, X2, X3)
MARK(b) → ACTIVE(b)
F(X1, X2, mark(X3)) → F(X1, X2, X3)
F(active(X1), X2, X3) → F(X1, X2, X3)
MARK(f(X1, X2, X3)) → F(X1, mark(X2), X3)
MARK(c) → ACTIVE(c)
F(X1, active(X2), X3) → F(X1, X2, X3)
ACTIVE(c) → MARK(b)
F(X1, X2, active(X3)) → F(X1, X2, X3)
F(mark(X1), X2, X3) → F(X1, X2, X3)
MARK(f(X1, X2, X3)) → ACTIVE(f(X1, mark(X2), X3))
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
ACTIVE(f(b, X, c)) → F(X, c, X)
MARK(f(X1, X2, X3)) → MARK(X2)
ACTIVE(f(b, X, c)) → MARK(f(X, c, X))
F(X1, mark(X2), X3) → F(X1, X2, X3)
MARK(b) → ACTIVE(b)
F(X1, X2, mark(X3)) → F(X1, X2, X3)
F(active(X1), X2, X3) → F(X1, X2, X3)
MARK(f(X1, X2, X3)) → F(X1, mark(X2), X3)
MARK(c) → ACTIVE(c)
F(X1, active(X2), X3) → F(X1, X2, X3)
ACTIVE(c) → MARK(b)
F(X1, X2, active(X3)) → F(X1, X2, X3)
F(mark(X1), X2, X3) → F(X1, X2, X3)
MARK(f(X1, X2, X3)) → ACTIVE(f(X1, mark(X2), X3))
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
F(X1, active(X2), X3) → F(X1, X2, X3)
F(X1, X2, active(X3)) → F(X1, X2, X3)
F(mark(X1), X2, X3) → F(X1, X2, X3)
F(X1, mark(X2), X3) → F(X1, X2, X3)
F(X1, X2, mark(X3)) → F(X1, X2, X3)
F(active(X1), X2, X3) → F(X1, X2, X3)
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
F(X1, active(X2), X3) → F(X1, X2, X3)
F(mark(X1), X2, X3) → F(X1, X2, X3)
F(X1, X2, active(X3)) → F(X1, X2, X3)
F(X1, mark(X2), X3) → F(X1, X2, X3)
F(X1, X2, mark(X3)) → F(X1, X2, X3)
F(active(X1), X2, X3) → F(X1, X2, X3)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ RuleRemovalProof
MARK(f(X1, X2, X3)) → MARK(X2)
MARK(f(X1, X2, X3)) → ACTIVE(f(X1, mark(X2), X3))
ACTIVE(f(b, X, c)) → MARK(f(X, c, X))
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
MARK(f(X1, X2, X3)) → MARK(X2)
POL(ACTIVE(x1)) = 2·x1
POL(MARK(x1)) = 2·x1
POL(active(x1)) = x1
POL(b) = 0
POL(c) = 0
POL(f(x1, x2, x3)) = 1 + x1 + 2·x2 + x3
POL(mark(x1)) = x1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ RuleRemovalProof
↳ QDP
↳ NonTerminationProof
MARK(f(X1, X2, X3)) → ACTIVE(f(X1, mark(X2), X3))
ACTIVE(f(b, X, c)) → MARK(f(X, c, X))
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)
MARK(f(X1, X2, X3)) → ACTIVE(f(X1, mark(X2), X3))
ACTIVE(f(b, X, c)) → MARK(f(X, c, X))
active(f(b, X, c)) → mark(f(X, c, X))
active(c) → mark(b)
mark(f(X1, X2, X3)) → active(f(X1, mark(X2), X3))
mark(b) → active(b)
mark(c) → active(c)
f(mark(X1), X2, X3) → f(X1, X2, X3)
f(X1, mark(X2), X3) → f(X1, X2, X3)
f(X1, X2, mark(X3)) → f(X1, X2, X3)
f(active(X1), X2, X3) → f(X1, X2, X3)
f(X1, active(X2), X3) → f(X1, X2, X3)
f(X1, X2, active(X3)) → f(X1, X2, X3)